思想:十进制转十六进制,只需要将十进制数num&15,然后num右移四位(num>>>4);这里使用查表法,即把‘0’-‘F’放在数组chs中,然后将chs[num&15]的值福遇到新的数组arr或容器StringBuffer中。查表法可对负数求相应的十六进制。
精髓:先“与”后“移”。
class ToHex
{
public static void main(String[] args)
{
toHex_array(-60);//查表法可以针对负数求其十六进制。
//System.out.println("Hello World!");
}
//非查表法(最普通的方法)。重点在于
/*
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
*/
public static void toHex(int num){
StringBuffer sb=new StringBuffer();
int temp;
for(int i=0;i<8;i++){ //转成8位十六进制
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
}
System.out.print(sb.reverse());
}
/*
**********************下面两种方法都是用查表法进行实现数制转换的*****************************
*/
//用StringBuffer来存储
public static void toHex_table( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
StringBuffer sb=new StringBuffer();
for(int i=0;i<8;i++){
int temp=num&15;
//System.out.print(chs[temp]);
sb.append(chs[temp]);
num=num>>>4;
}
System.out.print(sb.reverse());
}
//用数组来存储
public static void toHex_array( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
char[] arr=new char[8];
int i=arr.length;
while(num!=0){
int temp=num&15;
arr[--i]=chs[temp];
num=num>>>4;
}
for(int j=i;j<arr.length;j++)
System.out.print(arr[j]);
}
}